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5 FIELD OF THE INVENTION 

The present invention relates in general to network-based voice communications, and 
more particularly to a method of supporting functionally based supplementary services 
implemented using H323 protocol. 

0 

S BACKGROUND OF THE INVENTION 



' H.323 is a well known standard for multi-media communication. This standard 

governs communications between terminals and other entities over a packet switched 
15 jS network. A person of ordinary skill in the art and who is familiar with the H.323 standard will 
'L_ understand the elements of establishing third party call control via a Gatekeeper. Briefly, 

upon powering up, a H.323 endpoint (desktop) implements a discovery process for 
\^ determining which Gatekeeper to register with. This can be effected in a number of ways, 
;=f such as by multicasting a message which identifies the endpoint (i.e. the GRQ message) to a 
20 predetermined multicast address. The assigned Gatekeeper then responds (i.e. the GCF/GRJ 

message) with its RAS channel address (i.e. IP address). Before attempting to place a call, the 
endpoint must register with the Gatekeeper (i.e. the RRQ message) by advising it of its 
transport address and any aliases (discussed below). Registration is then confirmed by the 
Gatekeeper (i.e. via the RCF/RRJ message). Actual call signaling takes place over an 
25 established channel between two H.323 endpoints using Q.931 messages. For third party (i.e. 

Gatekeeper) call control, the originating endpoint sends a H.225 Admission Request (ARQ) 
to the Gatekeeper over the previously established RAS channel. The Gatekeeper responds 
with an ACF message which specifies the call signaling transport address to use for the call 
setup. The originating endpoint then transmits a Setup message to the Gatekeeper which, in 
30 turn, sends a Setup message to the destination endpoint. The destination endpoint then sends 

an admission request (ARQ) to the Gatekeeper and receives an acknowledgment (ACF) 
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therefrom. Finally, a Connect message is sent from the destination endpoint to the Gatekeeper 
which contains the address of the originating endpoint for H.425 control messages to the 
originating endpoint. 

The inventor has recognized the desirability of adapting the H.323 standard to voice 
communications such as traditionally implemented via a PBX. However, the H.323 umbrella 
protocol standard only provides a limited set of recommendations in terms of supporting 
fiinctionally based supplementary services between a Gatekeeper (GK) and an Endpoint (EP), 
due to the relative newness of the standard. Thus, H.323 suffers from limitations in 
providing a ftiU range of PBX like fiinctionally based supplementary services. The use of a 
fiinctionally based supplementary service protocol requires a substantial amount of 
intelligence and knowledge of state within the Endpoint, which tends to make an Endpoint 
code heavy. 

The H.323 recommendation refers to the H.450 recommendation as the primary 
method for fimctionally based supplementary service signaling in the H.323 domain. The 
H.450 recommendation is new, with support for only eight supplementary services (as of Oct. 
99), and expanding at a current rate of only three supplementary services per year. 
Furthermore, the H.450 protocol is a cumbersome protocol since it is ASN.l based. 

Another available method of supplementary services signaling is through the use of 
"DTMF signaling". This is similar to the use of feature access code signaling methods seen 
in traditional telephony. However, DTMF signaling is also not an ideal method for providing 
supplementary services since it usually requires a user to remember a complicated set of 
access codes and is therefore error prone. 

SUMMARY OF THE INVENTION 

According to the present invention, a simple supplementary service protocol (SSSP) 
is provided for implementing fiinctionally based supplementary services using the H.323 
standard. According to the preferred embodiment, a generic and expandable protocol is 
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provided for passing supplementary services information between H.323 entities for the 
provision of over twenty classes of functionally based supplementary services. The protocol 
of the present invention is relatively lightweight (i.e. not code intensive) compared to H.450 
since it does not rely on ASN. 1 encoding. In addition, the mixture of functional and 
stimulus protocol concepts in the design of the inventive protocol results in robust functional 
characteristics and implementation capability using only lightweight Endpoints. 

According to another aspect of the invention, a user interface is provided at an 
Endpoint for the purpose of displaying call and feature information relating to a SSSP 
enabled device, without the requirement of an elaborate state machine. 

BRIEF DESCRIPTION OF THE DRAWINGS 

An embodiment of the invention is described below with reference to the 
accompanying drawings, in which: 

Figure 1 is a schematic representation of a network-based communication system 
implemented according to the H.323 standard, including a Gatekeeper, an Application Server 
and a plurality of H.323 devices; 

Figure 2 shows message flow between the Gatekeeper and H.323 endpoint for SSSP 
message transport, according to the preferred embodiment; 

Figure 3 shows message flow using SSSP for implementing a message waiting 
indication; 

Figure 4 shows message flow using SSSP for implementing an endpoint maintenance 
data indication; 

Figure 5 shows message flow using SSSP for implementing ACD agent login and 

logout; 




Figure 6 shows message flow using SSSP for implementing a make busy, DND, 
cancel work timer; 

5 Figure 7 shows message flow using SSSP for disabling a make busy, DND, cancel 

work timer; 

Figure 8 shows message flow using SSSP for unparking a call; 
10 Figure 9 shows message flow using SSSP for implementing a back to held feature; 

H Figure 10 shows message flow using SSSP for implementing a force party release; 

1^ Figure 1 1 shows message flow using SSSP for implementing a recall feature; 

15 ill 

ri Figure 12 shows a first portion of message flow using SSSP for implementing a call 

: transfer with consultation; 

il Figure 13 shows a second portion of message flow using SSSP for implementing a 

20 call transfer with consultation; 

Figure 14 shows a first portion of message flow using SSSP for implementing a blind 
call transfer; 

25 Figure 15 shows a second portion of message flow using SSSP for implementing a 

blind call transfer; 

Figure 16 shows message flow using SSSP for implementing a call forward out of 
service, busy, always feature; 
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Figure 17 shows message flow using SSSP for implementing a call forward no answer 

feature; 

Figure 18 shows a first portion of message flow using SSSP for implementing a 
system camp-on and swap; 

Figure 19 shows a second portion of message flow using SSSP for implementing a 
system camp-on and swap; 

Figure 20 shows a first portion of message flow using SSSP for implementing ad hoc 
conference expansion; 

Figure 21 shows a second portion of message flow using SSSP for implementing ad 
hoc conference expansion; 

Figure 22 shows a first portion of message flow using SSSP for implementing a 
conference invite; 

Figure 23 shows a second portion of message flow using SSSP for implementing a 
conference invite; 

Figure 24 shows message flow using SSSP for implementing a group pickup feature; 
Figure 25 shows message flow using SSSP for implementing a directed pickup 

feature; 

Figure 26 shows message flow using SSSP for implementing a night service feature; 

Figure 27 is a representation of two user interface views for displaying normal call 
and feature information, according to a further aspect of the invention; 



Figure 28 is a flowchart showing implementation of a display handler for the user 
interface of Figure 27; 

Figure 29 shows a message flow using SSSP for implementing a call forward busy 
5 indication; and 

Figure 30 is a flowchart showing implementation of a state update handler for the user 
interface of Figure 27. 

10 DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

P • 

H Figure 1 shows a typical H.323 system, with H.323 endpoints 1 to 3 and a Gatekeeper 

4 connected to a LANAVAN 5, according to a fiilly-routed H.323 Model. An Application 
1^ Server 6 is also connected to the LANAVAN 5, which uses TAPI, TSAPI or JTAPI to control 
15 ^ endpoints for telephony applications. The Simple Supplementary Services Protocol (SSSP) of 
n the present invention is a generic communication scheme between a server entity (such as 
j'f H.323 Gatekeeper 4) and an associated Endpoint 1 (such as a H.323 Terminal) or between 
m Endpoints 1 . The SSSP provides a method of call signaling and control signaling that can be 
ill carried over existing protocols that support "user-to-user" like information (such as H.323 or 
20 ISDN). The following portions of the disclosure describe an encoding method according to 

the present invention, primitive definition, expandability rules, and the preferred transport 
method for SSSP. This is followed by illustrations of SSSP as a feature protocol between 
H.323 Gatekeeper 4 and H.323 Endpoint 1. 

25 A generalized method of Alpha Numeric String Encoding and Dual Tone Multiple 

Frequency (DTMF) String Encoding for a SSSP Protocol Data Unit (PDU) is provided, as set 
forth below. Alpha Numeric is the preferred method of encoding when used in H.323 
systems. The DTMF String Encoding method is restricted to the traditional DTMF character 
set. As such, it allows SSSP to be ported to non-H.323 conmiunication systems with ease. 
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General Encoding Terminology 

AlphaNumericType ::= sequence of characters of set (A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q, R, S, T, 
U, V, W, X, Y, Z, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9} 

DirectoryNumberType ::= sequence of characters of set {0,l,2,3,4,5,6,7,8s9,#,*,!}, 
NumberType ::= sequence of characters of set {0,1,2,3,4,5,6,7,8,9} 

MacAddressType \ = MacParm MacParam MacParam MacParam MacParam 
MacParam 

Where MacParam NumberType (MaxSize(3)) 
Alpha Numeric String Encoding 
SSSPTag:: = 'SF 

PrimitiveName AlphaNumbericType 
ParmeterSeperator ::= *,* 
PDUType ::= T | 'Q' | 'R' | 'C | 

Parameters /= DirectoryNumberType \ MacAddressType \ NumberType 

ParameterExtenstions :: = ParameterSeperator Parameters 
EndTag ::= NULL (0x00 for ASCII and 0x0000 for Unicode) 

PDUName ::= SSSPTag ParameterSeperator PrimitiveName PDUType 

SSSP PDU(String Encoding) 

PDUName ParameterExtensions EndTag. 



In the foregoing encoding method, the following restrictions apply: 

• SSSPTag is limited to 2 characters wide 

• PrimitiveName is limited to 3 characters wide. The first 2 characters are unique for each 
class of supplementary service. For example, all call forwarding features begin with CF 
and the agent login/logout feature begins with AL. 

• PDUType is limited to 1 character wide, wherein T = Indication; 'Q' = Request; *R' = 
Response; 'C = Command; 'E' = Error 

• The SSSP PDU (String Encoding) is limited to 16384 characters wide 



Thus, for example, a call forward busy indication containing the forwarded 
destination directory number is formatted as follows: 

• PDUName ::=SP,CFBI 

• ParameterExtensions ::= DirectoryNumber 

• SSSP PDU ::= SP,CFBI,DirectoryNumber 



DTMF String Encoding 

FeatureTag ::= 'AC 
FeatureCode ::= NumberType 
5 ParameterSeperator ::=**' 

Params ::= NumberType 
ParamExten :;= ParameterSeperator Params 
ACEndTag NULL (0x00 for ASCII and 0x0000 for Unicode) 
SSSP PDU( Access Code) ::= 
10 FeatureTag FeatureCode ParamExten* ACEndTag 

In the foregoing encoding method, the following restrictions apply: 

• The SSSP PDU (Access Code Encoding) is limited to 16384 characters wide 

• FeatureCode is limited to 6 characters 

15 

S Primitive Definition 

According to the preferred embodiment at the time of this specification, five 
:"T PDUTypes have been established including Indication, Command, Request, Response, and 
20 y Error. The definitions are as follows: 

Indication: a message that contains information but does not require action or response. 
\^ Command: a message that requires action but no explicit response. 

Request: a message that results in action by the remote device and requires an immediate 
25 response firom it. 

Response: a message that is the response to a request. 
Error: a message indicating exception information. 



The following portions of this disclosure illustrate the use of SSSP for providing 
30 Gatekeeper implemented supplementary services. Table 1 provides a summary of example 

SSSP command and indication primitives. Table 2 provides a simmiary of example SSSP 
requests and responses. Table 3 lists requests for code enimieration, while Table 4 lists 
response code enumeration. Table 5 lists SSSP primitive descriptions. Table 6 lists error 
codes. 
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' Table 1: Command and Indication Primitive Summary* 

Where: 



DirectoryNumber ::= DirectoryNumberType (MaxSize{255)) 
TotalMessages NumberType (MaxSize(5)) 
Mac Address ::= MacAddressType 
ToneNumber ::= NumberType (MaxSize(5)) 
ToneDuration ::= NumberType (MaxSize(5)) 
Versionldentifier ::= NumberType (MaxSize(5)) 
ErrorNumber ::= NumberType (MaxSize(8)) 
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FORCE PARTY RELEASE REQUEST 
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AC51 


FORCE PARTY RELEASE RESPONSE 


SP,FPRR,ResponseCode 


AC52*ResponseCode 


GROUP PICKUP REQUEST 


SP,GPQ 


AC53 


GROUP PICKUP RESPONSE 


SP.GPR.ResponseCode 


AC54*ResponseCode 


HOLD REQUEST 


SP,HDQ 


AC55 


HOLD RESPONSE 


SP,HDR,ResponseCode 


AC56*ResponseCode 


MAKE BUSY REQUEST 


SP.MBYQ.RequestCode 


AC57*RequestCode 


MAKE BUSY RESPONSE 


SP,MBYR,ResponseCode 


AC58*ResponseCode 


NIGHT SERVICE PICKUP REQUEST 


SP.NPQ, DirectoryNumber 


AC59*DirectoryNumber 


NIGHT SERVICE PICKUP RESPONSE 
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PLAY CONTINUOUS TONE REQUEST 
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ration 
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SWAP REQUEST 


SP,SWPQ 


AC74 
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Table 2: Request Response Primitive Summary. 




Where: 

DirectoryNumber ::= DirectoryNumberType (MaxSi2e(255)) 
TotalMessages ::= NumberType (MaxSize(5)) 
Mac Address MacAddressType 
ToneNumber NumberType (MaxSize(5)) 
ToneDuration ::= NumberType (MaxSize(5)) 
Versionldentifier NumberType (MaxSize(5)) 
ErrorNumber ::= NumberType (MaxSize(8)) 
ResponseCode ::= NumberType (MaxSize(16)) 
RequestCode ::= NumberType (MaxSize(16)) 



Request Code Description 


Request Code Value 


Disable Feature 


0 


Enable Feature 


1 



Table 3: Request Code Enumeration. 



Response Code Description 


Response Code Value 


Request Failed 


0 


Request Successful 


1 



Table 4: Response Code Enumeration. 



AGENT LOGIN 


COMMAND 

REQUEST 

RESPONSE 


A command sent from an EP to a GK to indicate that the EP wishes to become 
an ACD Agent. 

A request sent from an EP to a GK to indicate that the EP wishes to become an 
ACD Agent. 

A response to a Agent Login Request indicating if the request was successful or 
not successful. 


AGENT LOGOUT 


COMMAND 


A command sent from an EP to a GK to indicate that the EP wishes logout as an 
ACD Agent. 


REQUEST 


A request sent from an EP to a GK to indicate that the EP wishes logout as an 
ACD Agent. 


RESPONSE 


A response to a Agent Logout Request indicating if the request was successful 
or not successful. 


AGENT 


INDICATION 


An indication sent from a GK to an EP indicating the current state of the EP as 
an ACD Agent. The message indicates whether the EP is seen as an ACD 
Agent or not as an ACD agent by the GK. 


BACK TO HELD 


COMMAND 


A command sent from an EP to the GK to instruct the GK to release the current 
active call and swap back to the held call on consultation hold. 


REQUEST 


A request sent from an EP to the GK to instruct the GK to release the current 
active call and swap back to the held call on consultation hold. 


RESPONSE 


A response to a Back to Held Request indicating if the request was successful or 
not successful. 


CALL FORWARD 
ALWAYS 


INDICATION 


An indication sent from the GK to an originating EP that the call has been 






redirected to another endpoint due to the call forward always feature set by 
original destination. 


CALL FORWARD 
BUSY 


INDICATION 


An indication sent from the GK to an originating EP that the call has been 
redirected to another endpoint due to the call forward busy feature set by 
original destination. 


CALL FORWARD 
NO ANSWER 


INDICATION 


An indication sent from the GK to an originating EP that the call has been 
redirected to another endpoint due to the call forward no answer feature set by 
original destination. 


CALL FORWARD 
OUT OF SERVICE 


INDICATION 


An indication sent from the GK to an originating EP that the call has been 
redirected to another endpoint due to the call forward out of service feature set 
by original destination. 


CALLING LINE 
IDENTIFIER 


INDICATION 


An indication sent from the GK to an EP stating the destination alias 
(DirectoryNumber) of the current destination that the Endpoint is in call with. 


CALLING 
PROGRESS 


INDICATION 


An indication from the GK to an EP stating that the GK is making a call on 
behalf of that endpoint. 


CALLING WAITING 


INDICATION 


An indication from the GK to a busy EP that an EP has been camped on to it by 
the system. 


CANCEL WORK 
TIMER 


COMMAND 


A command sent from an EP to the GK to indicate that it wishes to enable or 
disable the Cancel Work Timer feature. 


INDICATION 


An indication sent from the GK to an EP indicating the current state of the work 
timer (if the work timer is currently canceled or not). 


REQUEST 


A request sent from an EP to the GK to indicate that it wishes to enable or 
disable the Cancel Work Timer feature. 


RESPONSE 


A response to a Cancel Work Timer Request indicating if the request was 
successful or not successful. 


CONFERENCE 


COMMAND 


A command sent from an EP, that originated a consultation call, to the 
GK/Multipoint Controller (MC) that it wishes to conference in the current party 
into an existing conference that the originating EP is in. If the situation 
involves starting a three party conference, then the party on consultation hold 
will be brought into the active conference (adhoc conference expansion). 


INDICATION 


An indication sent from the GK/MC to an endpoint that the conference has been 
initiated or a new participant has entered the conference. 


REQUEST 


A request sent from an EP, that originated a consultation call, to the 
GK/Multipoint Controller (MC) that it wishes to conference in the current party 
into an existing conference that the originating EP is in. If the situation 
involves starting a three party conference, then the party on consultation hold 
will be brought into the active conference (adhoc conference expansion). 




RESPONSE 


A response to a Conference Request indicating if the request was successful or 
not successful. 


CONSULTATION 
CALL 


COMMAND 


A command sent from an EP to the GK indicating that it wishes to place a 
consultation call to a destination. 


REQUEST 


A request sent from an EP to the GK indicating that it wishes to place a 
consultation call to a destination. 


RESPONSE 


A response to a Consultation Call Request indicating if the request was 
successful or not successful. 


DIRECTED PICKUP 


COMMAND 


A command sent from an EP to the GK to indicate that it wishes to perform a 
directed pickup. 


REQUEST 


A request sent from an EP to the GK to indicate that it wishes to perform a 
directed pickup. 


RESPONSE 


A response to a Directed Pickup Request indicating if the request was 
successful or not successful. 


DO NOT DISTURB 


COMMAND 


A command sent from an EP to the GK to indicate that it wishes to enable or 
disable the Do Not Disturb feature. 


INDICATION 


An indication sent from the GK to an EP to indicate the status of the Do Not 
Disturb feature. 


REQUEST 


A request sent from an EP to the GK to indicate that it wishes to enable or 
disable the Do Not Disturb feature. 


RESPONSE 


A response to a Do not Disturb Request indicating if the request was successful 
or not successful. 


ENDPOINT 
MAINTENANCE 


INDICATION 


The purpose of this message is to send any pertinent maintenance information 
from an Endpoint to a GK. 


ERROR 


INDICATION 


An indication providing an entity feedback on an exception situation. The 
supported error codes are listed in Table 6. 


FORCE PARTY 
RELEASE 


COMMAND 


A command sent from an EP to a GK to instruct the GK to keep the current 
active call and release the party that was placed on consultation hold by the EP 


REQUEST 


A request sent from ein EP to a GK to instruct the GK to keep the current active 
call and release the party that was placed on consultation hold by the EP 


RESPONSE 


A response to a Force Party Release Request indicating if the request was 
successful or not successful. 


GROUP PICKUP 


COMMAND 


A command sent from an EP to the GK to indicate that it wishes to perform a 
group pickup. 


INDICATION 


An indication sent from the GK to an EP that the group pickup option is 
available or unavailable to the EP . 


REQUEST 


A request sent from an EP to the GK to indicate that it wishes to perform a 
group pickup. 


RESPONSE 


A response to a Group Pickup Request indicating if the request was successful 
or not successful. 


HOLD 


COMMAND 


A command sent from an EP to the GK to instruct the GK to place the current 
call the EP is involved in on hold. 


INDICATION 


An indication sent from the GK to an EP that it has been placed on hold by the 
GK. 




REQUEST 


A request sent from an EP to the GK that asks the GK to place the current call 
the EP is involved in on hold. 


RESPONSE 


A response to a Hold Request indicating if the request was successful or not 
successful. 


MAKE BUSY 


COMMAND 


A command sent from an EP to the GK to indicate that it wishes to enable or 
disable the Make Busy feature. 


INDICATION 


An indication sent from a GK to an EP to indicate the status of the Make Busy 
feature (whether the Make Busy feature is active or not). 


REQUEST 


A request sent from an EP to the GK to indicate that it wishes to enable or 
disable the Make Busy feature. 


RESPONSE 


A response to a Make Busy Request indicating if the request was successful or 
not successful. 


MESSAGE 
WAITING 


INDICATION 


An indication sent from the GK to an Endpoint to indicate that a message is 
available for the user. 


NIGHT SERVICE 
PICKUP 


COMMAND 


A command sent from an EP to the GK to indicate that it wishes to pickup a 
night call. 


REQUEST 


A request sent from an EP to the GK to indicate that it wishes to pickup a night 
call. 


RESPONSE 


A response to a Night Service Pickup Request indicating if the request was 
successful or not successful. 


PLAY CONTINUOUS 
TONE 


COMMAND 


A command from the GK to an EP to play a continuous audio tone. 


REQUEST 




RESPONSE 


A response to a Play Continuous Tone Request indicating if the request was 
successful or not successful. 


PLAY SHORT TONE 


COMMAND 


A command from the GK to an EP to play an audio tone for a finite duration. 


REQUEST 




RESPONSE 


A response to a Play Short Tone Request indicating if the request was 
successful or not successful. 


SWAP 


COMMAND 


A command sent from an EP to the GK to swap the call that the EP is involved 
with to a camped on call or a call on hold. 


REQUEST 




RESPONSE 


A response to a Swap Request indicating if the request was successful or not 
successful. 


UN-PARK 


COMMAND 


A command sent from an EP to the GK to retrieve a parked call. 


REQUEST 


A request sent from an EP to the GK to retrieve a parked call. 


RESPONSE 


A response to a Un-Park Request indicating if the request was successful or not 
successful. 



Table 5: SSSP Primitive Description. 
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Error 
Number 


Error Code Name 


Error Code Description 


0 


Reserved 


Not to be used 


1 


ConferenceUnknownError 


A conference operation has failed. The reason for failure is 
not known. 



Table 6: Error Codes for Error Indication. 



Rules for Expandability 

There are two groups of rules for expanding the SSSP protocol, one for 
AlphaNumeric String Encoding and the other for DTMF String Encoding. 

When adding new PDUs, the new PDU is defined based on the definition of 
PrimitiveName as set forth above. For extending existing PDU's, parameter expansion 
follows the rule of simply adding additional ParameterExtenstions to the end of the PDU. 

Previously defined parameters are not removed from an existing PDU when new 
versions of a PDU are implemented, for backward compatibility. Endpoints supporting older 
versions of SSSP ignore parameters outside the scope of their known PDU templates. 

Alphanumeric String Encoding Expansion Rules 

The following is an example of expanding an existing PDU: 
Pre-Conditions: 

1. The Consultation Call Command PDU is to be expanded to support an Alias Field. 
Additional Encoding: 
Parameter Extensions Required: 

1. UNICODESTRINGTYPE ::= sequence of 16 bit characters (UNICODE). 




2. Parameters ::= DirectoryNumberType \ NumberType \ MacAddressType \ 
UNICODESTRINGTYPE 

SSSP PDU: 

5 SP,CCC,DirectoryNumber,AliasName 

Where :DirectoryNumber ::- DirectoryNumberType {MaxSizQ(255)) 
AliasName ::= UNICODESTRINGTYPE (MaxSizQ(255)) 

DTMF String Code Encoding Expansion Rules 

10 

Q The following is a example of expanding an existing PDU: 

Pre-Conditions : 

\^ 
15M 

i = I 

m 1 . The Hold Indication PDU will be expanded to support the IP address of the Music on 
'L, Hold source to connect to. 

! J Additional Encoding: 

20;3 

Parameter Extensions Required: 

7. ^ IP4AddressType ::= IP4Parm IP4Param IP4Param IP4Param 
Where IP4 Par am NumberType (MdLxS\zQ{3)) 
25 2. Parameters ::= NumberType \ IP4 Address Type 

SSSP PDU: 

SP,HDI,MusicOnHoldAddress 

Where: MusicOnHoldAddress : := IP4AddressType 
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SSSP Transport 

Being an application layer protocol, SSSP can be carried within any non-standard 
data field of a H.225 or H.245 message. For the preferred embodiment set forth herein, SSSP 
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messages are carried within the RAS Location Request (LRQ) and Location Confirmation 
(LCF) messages in the following examples. 

Using LRQ/LCF for SSSP Transport 

SSSP messages are carried within the nonStandardData field of the LRQ and LCF 
message. For simplicity, the LRQ and LCF are not be used for address translation 
functionality and the sending and receiving entity regards the LRQ and LCF as a transport 
mechanism for SSSP only. An independent location request/response exchange is initiated 
for address translation services. 

Figure 2 provides illustrations for common SSSP message exchange scenarios 
between signaling entities. The examples shown are requests fi"om an EP 1 to a GK 4. 
Though not shown, the procedures for GK 4 to EP 1 exchange scenarios are the same as for 
EP 1 to GK4. 

Figure 2 (a) is a scenario where a SSSP message (SSSPl) is sent from an EP 1 to the 
GK 4 with SSSP message piggybacking disabled. The GK 4 receives the message and 
acknowledges it with a LCF. This is a simple request and acknowledge exchange. 

Figure 2 (b) provides an example where a SSSP request is lost or the 
acknowledgement for the SSSP request is lost. The timeout and retry mechanism specified 
by H.323 for LRQ/LCF/LRJ will determine this and the sender entity (EP 1) receives a time 
out error from the protocol stack. 

Figure 2 (c) illustrates a situation where an application proceeds to send two SSSP 
requests in parallel. This scenario is similar to "windowing" techniques for network 
protocols. 

Figure 2 (d) represents a "piggyback" situation. A SSSP message (SSSP2) is sent in 
the acknowledgement LCF to save a round trip delay. 




LRQ/LCF Attribute Encoding 



Attribute 


Value 


RequestSeqNum 


16 bit value 


Endpointldentifier 


Same as the value returned m H.323 
Registration Confirmation (RCF) Message 


Destinationlnfo 


Endpoints E.164 alias 


NonStandardData 


SSSP message 


ReplyAddress 


Endpoint RAS transport Address 


Sourcelnfo 


Not included 


CanMapAlias 


False 


Gatekeeperldentifier 


Not included 


Tokens 


Not included 


CryptoTokens 


Not included 


IntegrityCheckValue 


Not included 


Table 7: Endpoint Sending a SSSP Message in a LRQ. 


Attribute 


Value 


RequestSeqNum 


16 bit value, corresponding to the 
RequestSeqNum value in LRQ 


CallSignalAddress 


IP=0.0.0.0, Port=0 


RasAddress 


IP=0.0.0.0, Port=0 


NonStandardData 


Not Included 


Destinationlnfo 


Not Included 


DestinationCalllnfo 


Not Included 


DestinationType 


Not Included 


RemoteExtensionAddress 


Not Included 


AltemateEndpoints 


Not Included 


Tokens 


Not Included 


CryptoTokens 


Not Included 


IntegrityCheckValue 


Not Included 


Table 8: GK Responding to a SSSP Message in a LCF. 


Attribute 


Value 


RequestSeqNum 


16 bit value 


Endpointldentifier 


Not Included 


Destinationlnfo 


Endpoints E.164 alias 


NonStandardData 


SSSP message 


ReplyAddress 


GK RAS transport Address 


Sourcelnfo 


Not included 


CanMapAlias 


False 
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Gatekeeperldentifier 


Not included 


Tokens 


Not included 


CryptoTokens 


Not included 


IntegrityCheckValue 


Not included 


Table 9: GK Sending a SSSP Message in a LRQ, 


Attribute 


Value 


RequestSeqNum 


16 bit value, corresponding to the 
RequestSeqNum value in LRQ 


CallSignalAddress 


Endpoints Call Signaling Address 


RasAddress 


Endpoints RAS Address 


NonStandardData 


Not Included 


Destinationlnfo 


Not Included 


DestinationCalllnfo 


Not Included 


DestinationType 


Not Included 


RemoteExtensionAddress 


Not Included 


AltemateEndpoints 


Not Included 


Tokens 


Not Included 


CryptoTokens 


Not Included 


IntegrityCheckValue 


Not Included 



Table 10: Endpoint Responding to a SSSP Message in a LCF. 



Message Sequence Charts 

The following sub-sections contain message sequence charts (MSCs) to provide 
guidance for the developer to implement SSSP in Endpoints and Gatekeepers. The format of 
the MSG is as follows: 



MSC_MESSAGE ::= 

H.225/H.245MESSAGENAME H.225 '[* SSSPPDU 

Where: 

• MSC MESSAGE is a message in the MSG 

• H.225/H.245MESSAGENAME is the primitive name for a H.225/H.245MESSAGE (for example SETUP) 

• H.225 are parameters within the H.225 message 

• SSSPPDU represents the SSSPPDU 
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H.225 and H.245 parameters that are mandatory within the H.225 and H.245 message 
are not presented within the message diagrams of Figures 3 to 26, for simplicity. In addition, 
repetitive and well known interactions, such as the H.245 sequence for basic call, are not 
presented. The following H.225 parameter clarification should be noted: 

• CALLx: Represents all the necessary identifiers to represent call x. This includes Call Reference Value 
(CRV), Call Identifier (CalllD), and Conference Identifier (ConflD) 

• DDN: Destination Directory Number (Destination E. 1 64 Alias) 

Figures 3 to 7 are examples of Call Independednt Supplementary Services, whereas 
the scenarios of Figures 8 to 26 are examples of Call Dependent Supplementary Services. 

In the scenario of Figure 3 the GK 4 informs EP2 when messages are available or 
unavailable. 

The message sequence is as follows: 

1 . Assume that EP2 has just registered with the GK 4 and the GK 4 has determined that 
EP2 has messages available. 

2. The GK 4 sends a Message Waiting Indication SSP PDU with a parameter > 0 to 
indicate that there is a message available for EP2. Since the GK 4 does not have the 
capability of sending the amount of messages available to a user, the number of 
messages is defaulted to 1. This follows the same behavior for the SX2000 (LW29) 

3. Upon receiving the MWI, EP2 provides visual indication to indicate that one or more 
messages are available. This could be in the form of a flashing Light Emitting Diode 
(LED) or an icon on the phone LCD display. 

4. Once all the messages have been retrieved by the user at EP2, the GK 4 will send a 
MWI with a parameter of 0 to represent 0 messages available. 

5. Upon receiving the MWI with parameter 0, the Endpoint should remove all visual 
indications representing a waiting message. 

6. During the period of EP2's registration with the GK 4, the GK 4 may detenhine that 
more messages are available. If messages are determined to be available sometime 
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after the initial registration on EP2, the GK 4 shall follow the procedures outline in 
step 2 above. 

In the scenario of Figure 4 EP2 provides its Maintenance Data to the GK 4 after 
Registration with the GK 4. 

The message sequence is as follows: 
1 . After successfiil registration, EP2 should provide the GK 4 with maintenance data. 
Endpoint 2 sends a Endpoint Maintenance Data Indication containing the 
VersionNumber of 1 (SSSP version 1) and MacAddress of 24*128*0*18*99*255. 

Figure 5 shows ACD Agent Login and Logout. 

The message sequence is as follows: 
To Login: 

1. The user at EP2 has selected the option at the endpoint to login as an ACD Agent. 
The Terminal will prompt the user to enter a DN representing the Agent ID, the 
example has a code of 7658. Once the code is entered, EP2 will send an AGENT 
LOGIN COMMAND to the GK 4 containing a parameter of 7658. 

2. The GK 4 will send back an AGENT LOGIN INDICATION to the Terminal 
indicating if the user has become an agent or not. A parameter of * T indicates that 
the user at EP2 is considered an ACD Agent by the GK 4 (successfiil login). The EP 
should provide a visual indication (e.g. an icon) on the LCD display to indicate that 
the user is considered an agent. 

To Logout: 

1 . The user then selects the Agent Logout option. The Terminal will prompt the user to 
enter a DN representing the Agent ID (example 7658). EP2 sends an AGENT 
LOGOUT COMMAND with DirectoryNumber equal to the DN entered by the user. 

2. The GK 4 will send back an AGENT LOGIN INDICATION to the Terminal 
indicating if the user is an Agent or not an Agent. A parameter of '0' indicates that 
the GK 4 does not currently consider the user at EP2 as an ACD Agent (successfiil 




logout). The EP should remove all visual indication related to an Agent (e.g. remove 
icon). 

In the scenario of Figure 6 Enable Make Busy, DND, and Cancel Work Timer 
features are shown. 

The message sequence is as follows: 

1 . The user at EP2 selects an option at the endpoint to enable the MAKE BUSY, Do Not 
Disturb, or Cancel Work Timer. When the user selects the enable MAKE BUSY 
feature. EP2 will send a MAKE BUSY COMMAND SSSP PDU to the GK 4. When 
the user selects enable Do Not Disturb at the EP, EP2 will send a DO NOT DISTURB 
COMMAND. EP2 will send a CANCEL WORK TIMER COMMAND PDU to the 
GK 4 when the user selects enable Cancel Work Timer. Each of the PDUs will 
contain a parameter ' T to represent enabling of the feature. 

2. The GK 4 will send back the appropriate indications to the Terminal indicating the 
state of the command. If the feature is enabled, the parameter will be ' 1'. If the 
feature is still disabled a parameter *0' will be sent. 

In the scenario of Figure 7 Make Busy, DND, and Cancel Work Timer features 
previously enabled are disabled. 

The message sequence is as follows: 

1. The scenario is the reciprocal of the enable feature scenario listed above. The user 
selects the disable Make Busy, Do Not Disturb, or Cancel Work Timer option to 
disable the respective feature. The difference between the enabling and disabling 
scenario is the parameter sent in the SSSP PDU. A parameter of '0' is sent in the 
MAKE BUSY COMMAND, DO NOT DISTURB COMMAND, or CANCEL 
WORK TIMER COMMAND to represent disabling of the feature. 

2. The GK 4 will send back the appropriate indications to the Terminal indicating the 
state of the command. If the feature is enabled, the parameter will be ' T. If the 
feature is still disabled a parameter '0' will be sent. 
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In the scenario of Figure 8, a Unpark a call parked by an attendant feature is shown. 

The message sequence is as follows: 

1 . An attendant has parked EP2. Assuming EP2 is a H.323 Endpoint, the GK 4 will send a 
HOLD INDICATION SSSP PDU and a PAUSE message (TCS=0). EP2 should provide 
the appropriate visual indication that represents hold. 

2. The user of EPl is notified the parked call by some form of out of band method (such as 
an overhead page) 

3. The user at EPl proceeds to un-park the call by selecting the un-park feature option and 
enters a un-park code of 1200. 

4. EPl proceeds to initiate a call: 

- Sends an UN-PARK COMMAND SSSP PDU containing a parameter 1200 representing 
the un-park code. 

- The ARQ shall contain all mandatory parameters. In addition, the message shall not 
contain a destination alias. The message shall contain the GK 4 call signaling address as 
the destination call signaling address. 

- The SETUP message sent shall contain all mandatory parameters. The message shall 
not contain any source or destination addressing. 

- The CRV, Call ID, and Conference ID should be different than that for EP2. 

5. Once the GK 4 receives the UN-PARK COMMAND, the GK 4 will send a CONNECT 
message to EPl and proceed to send a CALLING LINE IDENTIFIER INDICATION 
SSSP PDU and a RESUME message (TCS not 0) to EP2. EP2 should display its default 
talk state display. 

6. Normal H.245 procedures occur between EPl and EP2 

In the scenario of Figure 9 a Back to Held feature is shown. 

The message sequence is as follows: 
1. The call between EPl and EP2 is on hold and EPl is in consultation call with EPS. 



24 

2. The user at EPl decides that he/she wishes to go back to the call with EP2 by selecting 
the Back to Held feature option. 

3. EPl sends a BACK TO HELD COMMAND SSSP PDU to the GK 4 in a 
H245USERINPUTINDICATION. 

5 4. The GK 4 drops the leg of the call between the GK 4 and EP3 

5. The GK 4 takes EP2 off hold by sending a TCS not equal 0 to EP2, and also sends a 
CALLING LINE IDENTIFIER INDICATION to EP2. EP2 should display its default 
talk state display. The GK 4 will also send a CALLING LINE IDENTIFIER SSSP PDU 
and TCS not equal 0 to EPL EPl should display its default talk state display. 

10 6. Normal H.245 connection procedures occur after both TCS not equal to 0. H.245 

messages are sent from the GK 4. 



In the scenario of Figure 10 a Force Party Release feature is shown. 



15 ' The message sequence is as follows: 

Q 1. EPl has EP2 on Consultation Hold. In addition EPl is in an active consultation call with 

l1 EP3. 

I — 

^ 2. The user at EPl decides to drop the held call with EP2 by selecting the force party release 

f-^ feature option. 

20 3. EPl sends a FORCE PARTY RELEASE COMMAND SSSP PDU to the GK 4. 

4. The GK 4 proxies disconnect procedures with EP2 and the half call with EP2 is" removed. 

1 . The GK 4 sends back a PLAY SHORT TONE COMMAND to EPl so it will provide 
audio indication of the outcome of the FORCE PARTY RELEASE COMMAND. 

25 In the scenario of Figure 11a Recall feature is shown (Single Call Scenario). 

The message sequence is as follows: 

1. EPl has EP2 on Consultation Hold. EPl is also in a consultation call with EPS. 

2. EPl ends the call with EP3. 

30 3. Normal disconnect procedures occur between EPl and EP3. EP2 is still on hold. 




4. The GK 4 proceeds to offer a call to EPl after the disconnect on behalf of EP2. The 
CRV, CalllD, and ConfID should be the same as the original call between EPl and EP2. 

5. EPl sends back ALERTING to indicate that EPl is ringing. However, the ALERTING 
message shall not be passed to EP2 

6. Once the user at EPl answers the call, EPl sends a CONNECT message back to the GK 
4. The GK 4 proceeds to remove EP2 off hold and normal H.245 connection procedures 
occur. 

In the scenario of Figures 12 and 13 Call transfer with consultation call is shown. 

The message sequence is as follows: 

1 . Assume EPl and EP2 are in a call (CALLl). The user at EPl wants to transfer the 
user on EP2 to EP3. 

2. The user at EPl selects the TRANS/CONF option or HOLD key. 

3. EPl provides a prompt to allow the user to enter a DN. Digits in this state are not 
taken as DTMF requests. 

4. The user at EPl enters the DN for EP3 and presses SEND. After pressing SEND, any 
additional digits entered are be considered as DTMF requests by the EP. 

5. EPl sends a CONSULTATION CALL COMMAND PDU containing the DN=1003. 

6. The GK 4 sends a PAUSE (TCS=0) command to both EPl and EP2. EP2 receives a 
HOLD INDICATION SSSP PDU prior to the PAUSE message. EP2 should provide 
some form of visual indication to inform the user at EP2 that he/she has been put on 
hold. 

7. The GK 4 places a new call to EP3. EP3 should have a different CRV and Call ID 
than EPl, and the same Conference ID as EPl . Once the SETUP message is sent to 
EP3 from the GK 4, the GK 4 will send a CALL PROGRESS INDICATION PDU 
containing DN=1003 back to EPl. EPl should provide visual indication to the user 
that a call is proceeding with EP3 who's DN is 1003. 

8. Once EP3 is ringing (ALERTING), the GK 4 instructs EPl to play local ringing 
through a PLAY TONE COMMAND SSSP PDU. Assume that a ToneNumber of 5 
represents local ringing. 
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9. Once EPS answers the consultation call, the GK 4 disables local ringing by sending a 
PLAY TONE COMMAND SSSP PDU with a ToneNumber of 0. In addition, the GK 
4 will send a CALLING LINE IDENTIFIER SSSP PDU to EPl. EPl should display 
the default talk state display at this point. 
5 10. The GK 4 sends a RESUME (TCS not 0) message to EPl and normal H.245 call 

procedxires occur between EPl and EP3. 
11. The user at EPl completes the call transfer by releasing the call. EPl sends a 

RELEASE COMPLETE to the GK 4. The GK 4 proxies the disconnect so only the 
leg between the GK 4 and EPl is dropped. 
10 ^ 12. The GK 4 sends a CALLING LESfE IDENTIFIER INDICATION SSSP PDU 
5 (containing the DN of EP2) to EP3 and a CALLING LINE IDENTIFIER 

INDICATION SSSP PDU (containing the DN of EPS) to EP2. EP2 and EPS should 
I— display their default talk state display. 

In IS. The GK 4 pauses EPS with a PAUSE message 
I5p 14. The GK 4 sends a RESUME message to both EP2 and EPS, and normal H.245 call 
O procedures occur. 

1= 

;^ In Figures 14 and 15 Blind transfer with consultation call is shown. 

t 

20 The message sequence is as follows: 

1. Steps 1 to 7 from Figures 12 and IS are followed. 

2. Once EPS is ringing (ALERTING), the GK 4 instructs EPl to play local ringing 
through a PLAY TONE COMMAND SSSP PDU. Assume that a ToneNumber of 5 
represents local ringing, 

25 3. The user at EPl decides to complete the call transfer at this point by hanging up the 

call (blind transfer). On reception of RELEASE COMPLETE, the GK 4 will send a 
PLAY TONE COMMAND to disable ringing. Note, the user may decide to hang-up 
prior to hearing local ringing to initiate the blind transfer. Basically, before EPl 
receives the PLAY TONE COMMAND. If this is the case, a PLAY TONE 

30 COMMAND will not be sent to EPl and the sequence continues with NSM(CALL2, 

[SP,CPI,1002]). 




4. The GK 4 sends a CALL PROGRESS INDICATION SSSP PDU (containing the DN 
of EP2) to EP3. EPS should display the proper visual indication to show that a call is 
proceeding with EP2. 

5. The GK 4 sends a CALL PROGRESS INDICATION SSSP PDU (containing the DN 
of EP3) to EP2. EP2 should display the proper visual indication to show that a call is 
proceeding with EPS. The GK 4 will also send a PLAY TONE COMMAND to EP2 
so that it would play ringing tone to the user. 

6. Once the user at EPS answers the call, EPS sends a CONNECT message to the GK 4. 

7. The GK 4 instructs EP2 to stop ringing with a PLAY TONE COMMAND. The GK 4 
also sends a RESUME (TCS not 0) message to EP2, and normal H.245 call 
procedures occur. 

8. The GK 4 sends A CALLING LINE IDENTIFIER SSSP PDU to EP2 and EPS. EP2 
and EPS should display the default talk state display at this point. 

In the scenario of Figure 16 Call Forward Out of Service, Busy, or Always is shown. 

The message sequence is as follows: ' 

1. The user at EPl wants to make a call to EP2 and proceeds with normal call operations 

2. EP2 is either Out of Service, Busy, or has Call Forward Always activated. Assume 
the call forwarding destination is set to EPS 

S. The GK 4 re-routes the call to EPS and normal call procedures between EPl and EPS 
occur with the following exception. Once the SETUP message is sent to EPS, the GK 
4 will send either a CALL FORWARD OUT OF SERVICE INDICATION (CFOI), 
CALL FORWARD BUSY INDICATION (CFBI), or CALL FORWARD ALWAYS 
INDICATION (CFAI) SSSP PDU to EPl in a NSM. The message sent depends on 
state at EP2. EP2 should have a different CRV than EPl, and the same Call ID and 
conference ID as EPl. EPl should provide the correct visual indication stating the 
type of call forwarding that has occurred and to which destination the call has been 
forwarded to. 

4. Once the user at EPS answers the call, a CONNECT message is sent by EPS to EPl 

through the GK 4. At this point, normal H.245 procedures occur. In addition, the GK 
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4 sends a CALLING LINE IDENTIFIER INDICATION SSSP PDU to EPl. EPl 
should display its default talk state display at this point. 

In the scenario of Figure 17 Call Forward No Answer is shown. 

The message sequence is as follows: 

The user at EPl wants to make a call to EP2 and proceeds with normal call operations 
No user is available to answer the call at EP2 and the ring timer in the GK 4 expires. 
Assume Call Forward No Answer is set for EP2 with a forwarding destination of EP3. 
The GK 4 proceeds to release the half call with EP2. 

The GK 4 makes a new call with EP3. Once the SETUP message is sent to EP3, the 
GK 4 will send a CALL FORWARD NO ANSWER INDICATION with the DN of 
EP3 to EPl. Assume EPl is still ringing. EP2 should have a different CRV than EPl, 
and the same Call ID and conference ID as EPl. EPl should provide the correct 
visual indication stating the type of call forwarding that has occurred and to which 
destination the call has been forwarded to. 

Normal call operations between EPl and EP3 occur once EP3 sends a CONNECT 
message to the GK 4. EPl should display its default talk state display when the 
CALLING LINE IDENTIFIER INDICATION is received by the Endpoint. 

In the scenario of Figures 18 and 19 System Camp-on and Swap is shown. 

The message sequence is as follows: 
EP2 and EP3 are in a call. 

The user at EPl proceeds to make a new call to EP3. Note the CRV, Call ID, and 
Conference ID used by EPl is different than the one used for the call between EP2 
and EP3. 

Assume system camp-on is enabled for the user of EPl. The GK 4 determines EP3 is 
busy and sends a CALL WAITING INDICATION SSSP PDU (with the 
DirectoryNumber Parameter = 1001) to EP3. EP3 should provide some form visual 
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indication indicating a camped on call to the user. The GK 4 will also instruct EP3 to 
play a short tone to provide audio indication to the user. 

4. The GK 4 sends a CONNECT message to EPl and proceeds to PAUSE the call 
initiated by EPl. A HOLD INDICATION is sent to EPl from the GK 4 and a 

5 PAUSE (TCS=0) message. EPl should provide some form of visual indication to 

indicate that EPS has been placed on hold by the system. 

5. The user at EP3 decides to swap the current call to EPl by selecting the swap feature 
option. 

6. EPS sends a SWAP COMMAND SSSP PDU to the GK 4. The GK 4 proceeds to 
10 place EP2 on hold by sending a HOLD INDICATION SSSP PDU and a PAUSE 

□ message. EP2 should provide some form of visual indication to the user that they 

have been placed on hold. 

7. The GK 4 sends a PAUSE message to EPS 

H 8. The GK 4 sends a CALLING LINE IDENTIFIER INDICATION to EPl. EPl should 
ISfji provide its default talk state display at this point. 

L 9. The GK 4 sends a CALLING LINE IDENTIFIER INDICATION to EPS. EPl should 

provide its default talk state display at this point, 
m 10. The GK 4 sends a RESUME (TCS not 0) to both EPl and EPS and normal H.245 call 
'2 procedures follow. 

20 

In the scenario of Figures 20 and 21 Adhoc Conference Expansion is shown. 

The message sequence is as follows: 
1. Steps 1 to 10 from Figures 12 and IS are followed. 
25 2. The user at EPl completes the conference by selecting the conference feature option. 

S. EPl sends a CONFERENCE COMMAND SSSP PDU in a NSM to the GK 4. 

4. The GK 4 pauses EPl and EPS by sending a PAUSE message to both EPl and EPS. 

5. The GK 4 sends a CONFERENCE INDICATION SSSP PDU to EPl, EP2, and EPS. 
Each endpoint shall provide some form of visual indication to the user to inform 

30 him/her that a conference event has occurred. The PLAY SHORT TONE 
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COMMAND SSSP PDU is also sent to each EP after CONFERENCE INDICATION 
to provide each user with a comfort tone (100 ms of tone in this example). 
6. The GK 4 sends a RESUME message to EPl, EP2, and EP3. The GK 4 will proxy 
the H.245 negotiation to move EPl, EP2, and EP3 to the conference bridge. This 
5 involves negotiating all the necessary Terminal Capability, Master Slave, and Open 

Logical exchanges on behalf of the conference bridge to get EPl, EP2, and EP3's 
RTP stream to the bridge. 

In the scenario of Figures 22 and 23 Conference Invite is shown. 

10 

O The message sequence is as follows: 

Q 1. Assume EPl EP2, and EP3 are in a conference. The user at EPl wishes to invite the 

user at EP3B into the conference, 
l^"^ 2. The user at EPl selects the consultation call option. 
15I31 3. EPl provides a prompt to allow the user to enter digits or the user can select a feature 
}^ option that does not require a prompt for digits. Digits in this state are not taken as 

DTMF requests. 

s 

m 4. The user at EPl enters the address for EP 3B. After entering the address for EP3 B, 
n any additional digits entered shall be considered as DTMF requests. 

20 5. EPl sends a CONSULTATION CALL COMMAND PDU containing the DN=1003. 

6. The GK 4 sends a PAUSE (TCS=0) command to both EP 1 . 

7. The GK 4 places a new call to EP3B. EP3B should have a different CRV and Call ID 
than EPl's original call, and the same Conference ID as EPl. Once the SETUP 
message is sent to EP 3B from the GK 4, the GK 4 will send a CALL PROGRESS 

25 INDICATION PDU containing DN=1 003 back to EP 1 . EP 1 should provide visual 

indication to the user that a call is proceeding with EP3 who's DN is 1004. 

8. Once EP 3B is ringing (ALERTING), the GK 4 instructs EPl to play local ringing 
through a PLAY TONE COMMAND SSSP PDU. Assume that a ToneNumber of 5 
represents local ringing. 

30 9. Once EP 3B answers the consultation call, the GK 4 disables local ringing by sending 

a PLAY TONE COMMAND SSSP PDU with a ToneNumber of 0. In addition, the 
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GK 4 will send a CALLING LINE IDENTIFIER SSSP PDU to EPl. EPl should 
display the default talk state display at this point. 
10. The GK 4 sends a RESUME (TCS not 0) message to EPl and normal H.245 call 
procedures occur between EPl and EP 3B. 
5 11. The user at EPl completes the conference invite by selecting the conference feature 

option. 

12. EPl sends a CONFERENCE COMMAND SSSP PDU in a 
H245USERINPUTINDICATION to the GK 4. 

13. The GK 4 pauses EPl and EP 3B by sending a PAUSE message to both EPl and EP4 
10 3B 

S 14. The GK 4 sends a CONFERENCE INDICATION SSSP PDU to EPl, EP2, EP3, and 
'si EP 3B. Each endpoint should provide some form of visual indication to the user to 

!1l inform him/her that a conference event has occurred. The PLAY SHORT TONE 

p COMMAND SSSP PDU is also sent to each EP after CONFERENCE INDICATION 

15^?^ to provide each user with a comfort tone (100 ms of tone in this example). 

13 15. The GK 4 sends a RESUME message to EPl and EP 3B. The GK 4 will proxy the 
H.245 negotiation to move EPl and EP 3B to the conference bridge. 
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In the scenario of Figure 24 a Group Pickup feature is shown. 



The message sequence is as follows: 

1. EPl calls a pickup group and assume EPl is in the alerting state. 

2. The GK 4 informs EP2 that a group pickup is available by sending it a GROUP 
PICKUP INDICATION SSSP PDU. EP2 should provide visual indication to the user 

25 at EP2 of an available group pickup. 

3. The user at EP2 wishes to perform a group pickup and selects the directed pickup 
feature option at EP2. 

4. EP2 proceeds to initiate a call: 

- Send a GROUP PICKUP COMMAND SSSP PDU to the GK 4 
30 - The ARQ shall contain all mandatory parameters. In addition, the message shall not 

contain a destination alias. The message shall contain the GK 4 call signaling address 
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as the destination call signaling address. 

- The SETUP message sent shall contain all mandatory parameters. The message 
shall not contain any source or destination addressing. 

- The CRV, Call ID, and Conference ID should be different than that for EPl. 
The GK 4 sends a CONNECT message to EP2 and EPl. 

Normal H.245 call procedures between EPl and EP2 

In the scenario of Figure 25 a Directed Pickup feature is shown. 
The message sequence is as follows: 

EPl calls EPS and both EPl and EP3 are in the alerting state. 

The user at EP2 wishes to perform a directed pickup and selects the directed pickup 

feature option at EP2 and then enters the pickup code. 

EP2 proceeds to initiate a call: 

- Send a DIRECTED PICKUP COMMAND SSSP PDU containing the pickup code 
(6500) as a parameter. 

- The ARQ shall contain all mandatory parameters. In addition, the message shall not 
contain a destination alias. The message shall contain the GK 4 call signaling address 
as the destination call signaling address. 

- The SETUP message sent shall contain all mandatory parameters. The message 
shall not contain any source or destination addressing. 

- The CRV, Call ID, and Conference ID should be different than that for EPl . 
The GK 4 releases the half call between EP2. 

The GK 4 sends a CONNECT message to EP2 and EPl. 
Normal H.245 call procedures between EPl and EP2. 

In the scenario of Figure 26 a Night Service feature is shown. 

The message sequence is as follows: 
Assume Night Service is active. 

An incoming call to the GK 4 from EPl is in progress. EPl is in the alerting state. 
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3. An out of band indication representing a night call is occurring. 

4. The user at EP2 wishes to perform a night service pickup and selects the night service 
feature option at EP2 and then enters the night service code. 

5. EP2 proceeds to initiate a call: 

- Send a NIGHT SERVICE PICKUP COMMAND SSSP PDU containing the night 
service code (7000) as a parameter. 

- The ARQ shall contain all mandatory parameters. In addition, the message shall not 
contain a destination alias. The message shall contain the GK 4 call signaling address 
as the destination call signaling address. 

- The SETUP message sent shall contain all mandatory parameters. The message 
shall not contain any source or destination addressing. 

- The CRV, Call ID, and Conference ID should be different than that for EPL 

6. The GK 4 sends a CONNECT message to EP2 and EP 1 . 

7. Normal H.245 call procedures between EPl and EP2. 

User Interface Support for SSSP 

A complicated state machine is traditionally required to keep user interfaces (UIs) in 
the correct context for displaying information related to a functionally based supplementary 
services protocol. The following portion of this disclosure provides a simplified 
implementation for providing a UI at an Endpoint for the purpose of display normal call and 
feature information related to a SSSP enabled device. 

The state handling required for UI display is simplified in the present invention by 
dividing the display into two views: a feature display, which handles all feature related 
displays needed during SSSP interaction, and a default display, which handles all non-SSSP 
related display information. By flipping between feature and default displays according to a 
small finite set of rules, an Endpoint can provide an effective UI without a need for a 
completed state machine, as set forth below. 

The term Default Display represents the normal status display view that a H.323 
Terminal supports (if the Terminal has a display capability). For optimal support of SSSP 




feature indications, according to the present invention the H.323 Terminal supports an 
additional view (referred to herein as the Feature Display) for display of feature information. 
The Feature Display is driven by SSSP indications and has the same visual dimensions as the 
Default Display. According to the invention, the H.323 terminal runs both views (Default 
and Feature) at any given time. Both displays are updated in real time. However, only one 
display is placed in the foreground (displayed) to the user at any given time. Based on set 
rules, the Feature Display and Default Display toggle back and forth from foreground to 
background. 

Figure 28, along with the information from Table 1 1, provides a summary of the logic 
required for toggling between the Default Display and Feature Display. As seen in Figure 28, 
there is a specific set of messages and events that cause the Default or Feature display to be 
placed into the foreground. The Feature Display is placed in the foreground on reception of 
specific SSSP indications listed in the table. The Default display is only placed in the 
foreground under a condition where the user ends the call, or on reception of a CALLE^G 
LINE IDENTIFIER INDICATION SSSP message. 



Message 


Back to Feature Display 


Back to Default Display 


CPI,DirectoryNumber 


Terminal displays: 

Linel: Call Proceeding 
Line2 : { DirectoryNumber } 

on the display 


Drop call, CLDI. 


HLDI 


Terminal displays: 
Line 1: ON HOLD 


Drop call, CLDI 


CFBI,DirectoryNumber 


The Terminal can optionally display: 

Linel: CF- Busy 

Line2: {DirectoryNumber} 


Drop call, CLDI 


CFOI,DirectoryNumber 


The Terminal can optionally display: 

Linel : CF- Out of Service 
Line2: {Directory Number} 


Drop call, CLDI 


CFAIjDirectoryNumber 


The Terminal can optionally display: 

Linel: CF- Always 
Line2: {DirectoryNumber} 


Drop call, CLDI 


CFNI,DirectoryNumber 


The Terminal can optionally display: 

Linel: CF- No Answer 
Line2: {DirectoryNumber} 


Drop call, CLDI 




CONI 


The Terminal will display: 
Linel: In Conference 


Drop call, CLDI 


CWI,DirectoryNumber 


The Terminal will display: 
Linel: Call Waiting 
Line2: {Directory Number} 


Drop call, CLDI 


ERRI,ErrorNumber 


The display text will be dependent on the 
ErrorNumber. 

By default the Terminal will display: 
Linel: Error - {Error#} 
Where {Error#} is the value of 
ErrorNumber. 

For ErrorNumber 1 
(Conference_Unknown_Error), the 
Terminal will display: 
Line 1 : Conference 
Line2: Operation Failed 


Drop call, CLDI 



Table 11: Messaging that Changes Feature and Default Display. 



The contents of the display shown in Table 1 1 is for example purposes only. The 
display text may be customized to the capability of the end device. In addition, the terms 
"linel:" and "line2: "represent the line location to display the text on the Terminal. 

Figure 29 illustrates how the principles discussed above provide an effective user 
interface, having regard to a Call Forward message exchange which illustrates toggling 
between the Default Display and Feature Display. 

1 . Scenario starts with a user at EP 1 calling a user at EP3. 

2. The Default Display is in the foreground at EPl 

3. The user at EPl dials 1002 and presses send. 

4. The Default Display is updated to indicate that the call is proceeding as usual 

5. The GK 4 determines EP2 is busy and reroutes the call to EPS 

6. The GK 4 sends CALL FORWARD BUSY INDICATION with DN 1003 to EPl 

7. EPl updates the Feature Display view with "CALL FORWARD BUSY: 1003". In 
addition, it sees that this is a message listed on Table 1 1 that will cause the Feature 
Display to move to the foreground. EPl flips the Feature Display to the foreground. 

8. The user at EP3 sees and incoming call and answers the call. EP3 is showing the Default 
Display and providing to usual basic call feedback to the user. 
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9. The GK 4 passes the CONNECT message to EPl 

10. EPl updates its Default Display indicating the call is connected to 1002. For example, 
"In Call: 1002". EPl still believes it is talking to EP2 since it is not interpreting the 
CALL FORWARD BUSY INDICATION. It is simply displaying it. The Default 
Display is in the background so the user still sees "CALL FORWARD BUSY: 1003". 

1 1. The GK 4 will send a CALLING LINE IDENTIFIER INDICATION (CLDI) message to 
EPl after the CONNECT message 

12. EPl sees the CLDI message and updates its current called party to 1003. It then updates 
the Default Display to say "In Call: 1003". Since CLDI is a message that will cause the 
Default Display to be moved to the foreground, EPl does so and the user sees the correct 
visual display. Why CLDI updates the default display will be shown in Section 0. 

13. Note: Feature Display still shows "CALL FORWARD BUSY: 1003". However, it is in 
the background and not shown to the user. 

Override of Operations from Indication Messages 

When the Terminal receives a message from Table 1 1, it cancels any existing 
operation that has been started. Then the Terminal displays the correct Feature or Default 
display in the foreground. 

For example: 

1. Terminal 1 is in call with Terminal2 

2. The user on Terminal2 presses a key and a list appears on Terminal2's display. The user 
on Terminal2 is undecided on what to do and the list stays on the screen. 

3. In the meantime, a HDI SSSP message is sent to Terminal2. 

4. Terminal2 then cancels the list, brings the Feature Display to the foreground and displays 
a hold message on the Feature Display. 

Indications that Affect State Value 




The discussion above illustrates how SSSP indications that manipulate the Feature 
Display so as to toggle the Feature Display from background to foreground. The rest of the 
SSSP indications change internal parameter/state values, particularly if a value is set or not. 



Message 


Change 


CLDIjDirectoryNumber 


Terminal updates the current party called default 
display with a directory number of 
{DirectoryNumber} 


MWI,1 orMWI ,0 


Terminal displays message waiting icon or removes 
the message waiting icon. This could be simply 
flashing the LED or have a specific icon on the 
display to represent message waiting 


AGTI,1 or AGTI,0 


Terminal displays the agent icon on the display or 
removes the agent icon off its display 


MBYI,1 orMBYI,0 


Terminal updates its menu item to display make 
busy feature is enabled or disabled 


DNDI,1 orDNDI,0 


Terminal updates its menu item to display the Do 
Not Disturb feature is enabled or disabled 


CWTI,1 orCWTI,0 


Terminal updates its menu item to display the 
cancel work timer feature is enabled or disabled 


GPI,1 or GPI,0 


Terminal displays a group pickup icon on the 
display or removes the group pickup icon from the 
display 



Table 12: Messaging Affecting State. 



As shown in Table 12, the indications sent to the Endpoint cause the endpoint to 
update its current parameter/state value for a particular feature. This includes whether to turn 
on an icon or off an icon, showing if a feature is enabled or disabled in a feature list, or 
updating it's current calling line identifier display. On reception of a message listed in Table 
12, the Endpoint follows the procedures listed in Figure 30. Following the example 
discussed above with reference to Figure 29 , EPl receives a CLDI message from the GK 4. 
EPl follows the rules in Table 12 and updates its parameter that stores the calling line 
identifier from 1002 to 1003 refreshes the Default Display. The Default Display is still in the 
background. EPl checks the rules stated by Table 1 1 and the Default Display is brought up 
to the foreground. 

Alternatives and variations of the invention are possible. For example, although 
H.2323 protocol is set forth as the existing protocol within which SSSP is transported, the 
principles of SSSP may be applied to ISDN, Tl or any other user-to-user communication 
protocol (i.e. any protocol which supports transparent tunneling of information. Also, 




although the specific implementation examples are directed to exchanges between the 
Gatekeeper and Endpoints, it will be understood by a person of skill in the art that SSSP may 
also be extended to communications between Endpoints. All such alternative embodiments 
and variations are believed to be within the sphere and scope of the claims appended hereto. 



